<template>
    <div class="mobile-page":style="{
		background:bottomBgColor,
		marginTop:mTop+'px',
		paddingTop:topConfig+'px',
		paddingBottom:bottomConfig+'px',
		paddingLeft:prConfig+'px',
		paddingRight:prConfig+'px'
		}">
		<div class="pointsMall" :style="{
				background:styleConfig?bgColor:bgColor2,
				borderRadius: bgRadius
			}">
			<div class="title acea-row row-between-wrapper" :style="
			  (styleConfig?
			  'backgroundImage:url(' + imgBgUrl + ')':
			  `background:linear-gradient(90deg,${headerBgColorLeft} 0%,${headerBgColorRight} 100%)`)
			">
				<div v-if="titleConfig" :style="(titleTabVal==2?'fontStyle:':'fontWeight:') + titleText+';color:'+titleColor+';fontSize:'+titleNumber+'px;'">{{titleTxtConfig}}</div>
				<img v-else :src="styleConfig?imgUrl:imgColorUrl" alt="" />
				<div class="more" :style="{
					color:styleConfig?headerBntColor:headerBntColor2,
					fontSize:bntNumber+'px'
				}">{{rightBntTxt}}<span class="iconfont iconjinru" :style="{
					fontSize:bntNumber+'px'
				}"></span></div>
			</div>
			<div class="conter" v-if="goodStyleConfig == 0">
				<div class="list bg--w111-fff">
					<div class="item" v-for="(item, index) in numberConfig" :key="index">
						<div class="pictrue acea-row row-center-wrapper" :style="{
							borderRadius: imgRadius
						}">
							<img src="../../assets/images/shan.png"/>
						</div>
						<div class="bottom" :style="{
							color:toneConfig?goodsPriceColor:'#fff',
							background: toneConfig?`linear-gradient(90deg,${priceBgColorRight} 0%,${priceBgColorLeft} 100%)`:themeColor
						}">68880积分+30元</div>
					</div>
				</div>
			</div>
			<div class="list on" v-else-if="goodStyleConfig == 1">
				<div class="item" v-for="(item, index) in numberConfig" :key="index">
					<div class="pictrue acea-row row-center-wrapper" :style="{
						borderRadius: imgRadius
					}">
						<img src="../../assets/images/shan.png" />
					</div>
					<div class="money acea-row row-middle"><img src="../../assets/images/points.png"/><span class="num" :style="{color:!toneConfig?(styleConfig?'#fff':colorStyle.theme):(styleConfig?goodsPriceColor:goodsPriceColor2)}">6888</span><span :style="{color:!toneConfig?(styleConfig?'#fff':'#282828'):(styleConfig?goodsUnitPriceColor:goodsUnitPriceColor2)}">+</span><span class="num" :style="{color:!toneConfig?(styleConfig?'#fff':colorStyle.theme):(styleConfig?goodsPriceColor:goodsPriceColor2)}">67</span><span :style="{color:!toneConfig?(styleConfig?'#fff':'#282828'):(styleConfig?goodsUnitPriceColor:goodsUnitPriceColor2)}">元</span></div>
					<div class="name" :style="{
						color:styleConfig?goodsNameColor2:goodsNameColor
					}">小米蓝牙耳机...</div>
				</div>
			</div>
			<div class="list on2" v-else>
				<div class="item" v-for="(item, index) in numberConfig" :key="index">
					<div class="pictrue acea-row row-center-wrapper" :style="{
						borderRadius: imgRadius
					}">
						<img src="../../assets/images/shan.png"/>
					</div>
					<div class="name" :style="{
						color:styleConfig?goodsNameColor2:goodsNameColor
					}">小米蓝牙耳机你值得拥有</div>
					<div class="money acea-row row-middle"><img src="../../assets/images/points.png"/><span class="num on" :style="{color:!toneConfig?(styleConfig?'#fff':colorStyle.theme):(styleConfig?goodsPriceColor:goodsPriceColor2)}">6888</span><span :style="{color:!toneConfig?(styleConfig?'#fff':'#282828'):(styleConfig?goodsUnitPriceColor:goodsUnitPriceColor2)}">+</span><span class="num" :style="{color:!toneConfig?(styleConfig?'#fff':colorStyle.theme):(styleConfig?goodsPriceColor:goodsPriceColor2)}">67</span><span :style="{color:!toneConfig?(styleConfig?'#fff':'#282828'):(styleConfig?goodsUnitPriceColor:goodsUnitPriceColor2)}">元</span></div>
				</div>
			</div>
		</div>
    </div>
</template>

<script>
    import { mapState, mapMutations } from 'vuex'
	// import theme from "@/mixins/theme";
	import Setting from '@/setting';
    export default {
        name: 'points_mall',
        cname: '积分商城',
        configName: 'c_points_mall',
        icon: '#iconzujian-jifenshangcheng',
        type:1,// 0 基础组件 1 营销组件 2工具组件
        defaultName:'pointsMall', // 外面匹配名称
        props: {
            index: {
                type: null,
                default: -1
            },
            num: {
                type: null
            },
			colorStyle:{
				type: null
			}
        },
        computed: {
            ...mapState('mobildConfig', ['defaultArray'])
        },
        watch: {
            pageData: {
                handler (nVal, oVal) {
                    this.setConfig(nVal)
                },
                deep: true
            },
            num: {
                handler (nVal, oVal) {
                    let data = this.$store.state.mobildConfig.defaultArray[nVal]
                    this.setConfig(data)
                },
                deep: true
            },
            'defaultArray': {
                handler (nVal, oVal) {
                    let data = this.$store.state.mobildConfig.defaultArray[this.num]
                    this.setConfig(data);
                },
                deep: true
            }
        },
		// mixins: [theme],
        data () {
            return {
                // 默认初始化数据禁止修改
                defaultConfig: {
					cname: '积分商城',
                    name: 'pointsMall',
                    timestamp: this.num,
					isHide:false,
					setUp: {
					  tabVal: 0
					},
					titleLeft:'头部设置',
					titleGoodsList:'产品列表',
					titleGoods:'产品设置',
					titleRight:'头部样式',
					titleGoodsStyle:'产品样式',
					titleCurrency:'通用样式',
					styleConfig:{
						title: '选择风格',
						tabVal: 1,
						tabList: [
							{
							  name: '背景色'
							},
						    {
						      name: '背景图片'
						    }
						]
					},
					titleConfig:{
						title: '标题类型',
						tabVal: 0,
						tabList: [
							{
							  name: '图片'
							},
						    {
						      name: '文字'
						    }
						]
					},
					imgBgConfig:{
						info: '建议：710px * 96px',
						url: Setting.apiBaseURL.replace(/adminapi/, '')+'statics/images/pointsBg.png',
						type:'code',
						delType:0,
						name:'背景图片'
					},
					imgConfig:{
						info: '建议：154px * 32px',
						url: require('@/assets/images/points01.png'),
						type:'code',
						delType:0,
						name:'标题图片'
					},
					imgConfig2:{
						info: '建议：154px * 32px',
						url: require('@/assets/images/points02.png'),
						type:'code',
						delType:0,
						name:'标题图片'
					},
					titleTxtConfig:{
						title: '标题文字',
						value: '积分兑好礼',
						place: '请输入标题文字',
						max: 10
					},
					rightBntConfig:{
						title: '右侧按钮',
						value: '更多',
						place: '请输入右侧按钮',
						max: 6
					},
					numberConfig:{
						title: '产品数量',
						val: 3,
						min: 1
					},
					goodStyleConfig:{
						title: '选择风格',
						tabVal: 0,
						tabList: [
							{
							  name: '样式1'
							},
						    {
						      name: '样式2'
						    },
							{
							  name: '样式3'
							}
						]
					},
					headerBgColor:{
						title: '背景颜色',
						name: 'headerBgColor',
						default: [
						    {
						        item: '#fff'
						    },
							{
							    item: '#fff'
							}
						],
						color: [
						    {
						        item: '#fff'
						    },
							{
							    item: '#fff'
							}
						]
					},
					titleText:{
						title: '标题文字',
						tabVal: 0,
						tabList: [
							{
							    name: '加粗',
							    style: 'bold'
							},
						    {
						        name: '正常',
						        style: 'normal'
						    },
						    {
						        name: '倾斜',
						        style: 'italic'
						    }
						]
					},
					titleColor:{
						title: '标题颜色',
						name: 'titleColor',
						default: [
						    {
						        item: '#333333'
						    }
						],
						color: [
						    {
						        item: '#333333'
						    }
						]
					},
					titleNumber:{
						title: '标题字号',
						val: 16,
						min: 0
					},
					headerBntColor:{
						title: '按钮颜色',
						name: 'headerBntColor',
						default: [
						    {
						        item: '#fff'
						    }
						],
						color: [
						    {
						        item: '#fff'
						    }
						]
					},
					headerBntColor2:{
						title: '按钮颜色',
						name: 'headerBntColor2',
						default: [
						    {
						        item: '#999'
						    }
						],
						color: [
						    {
						        item: '#999'
						    }
						]
					},
					bntNumber:{
						title: '按钮字号',
						val: 12,
						min: 0
					},
					filletImg:{
						title:'产品圆角',
						type: 0,
						list: [
						  {
						    val: "全部",
						    icon: "iconcaozuo-zhengti",
						  },
						  {
						    val: "单个",
						    icon: "iconcaozuo-bianjiao",
						  }
						],
						valName:'圆角值',
						val: 5,
						min: 0,
						valList:[
							{val:0},
							{val:0},
							{val:0},
							{val:0}
						]
					},
					goodsNameColor:{
						title: '产品名称',
						name: 'goodsNameColor',
						default: [
						    {
						        item: '#282828'
						    }
						],
						color: [
						    {
						        item: '#282828'
						    }
						]
					},
					goodsNameColor2:{
						title: '产品名称',
						name: 'goodsNameColor2',
						default: [
						    {
						        item: '#fff'
						    }
						],
						color: [
						    {
						        item: '#fff'
						    }
						]
					},
					goodsUnitPriceColor2:{
						title: '价格单位',
						name: 'goodsUnitPriceColor2',
						default: [
						    {
						        item: '#282828'
						    }
						],
						color: [
						    {
						        item: '#282828'
						    }
						]
					},
					goodsUnitPriceColor:{
						title: '价格单位',
						name: 'goodsUnitPriceColor',
						default: [
						    {
						        item: '#fff'
						    }
						],
						color: [
						    {
						        item: '#fff'
						    }
						]
					},
					toneConfig:{
						title: '色调',
						tabVal: 0,
						tabList: [
							{
							  name: '跟随主题风格'
							},
						    {
						      name: '自定义'
						    }
						]
					},
					goodsPriceColor:{
						title: '产品价格',
						name: 'goodsPriceColor',
						default: [
						    {
						        item: '#fff'
						    }
						],
						color: [
						    {
						        item: '#fff'
						    }
						]
					},
					goodsPriceColor2:{
						title: '产品价格',
						name: 'goodsPriceColor2',
						default: [
						    {
						        item: '#E93323'
						    }
						],
						color: [
						    {
						        item: '#E93323'
						    }
						]
					},
					priceBgColor:{
						title: '价格背景',
						name: 'priceBgColor',
						default: [
							{
								item: '#FF7931'
							},
							{
								item: '#E93323'
							}
						],
						color: [
							{
								item: '#FF7931'
							},
							{
								item: '#E93323'
							}
						]
					},
					moduleColor: {
					    title: '组件背景',
					    name: 'moduleColor',
					    default: [
					    	{
					    		item: '#FF7931'
					    	},
					    	{
					    		item: '#E93323'
					    	}
					    ],
					    color: [
					    	{
					    		item: '#FF7931'
					    	},
					    	{
					    		item: '#E93323'
					    	}
					    ]
					},
					moduleColor2: {
					    title: '组件背景',
					    name: 'moduleColor',
					    default: [
					    	{
					    		item: '#fff'
					    	},
					    	{
					    		item: '#fff'
					    	}
					    ],
					    color: [
					    	{
					    		item: '#fff'
					    	},
					    	{
					    		item: '#fff'
					    	}
					    ]
					},
					bottomBgColor: {
					    title: '底部背景',
					    name: 'bgColor',
					    default: [
					    	{
					    		item: '#f5f5f5'
					    	}
					    ],
					    color: [
					    	{
					    		item: '#f5f5f5'
					    	}
					    ]
					},
					topConfig: {
					    title: '上边距',
					    val: 0,
					    min: 0
					},
					bottomConfig: {
					    title: '下边距',
					    val: 0,
					    min: 0
					},
					prConfig: {
					    title: '左右边距',
					    val: 10,
					    min: 0
					},
					mbConfig: {
					    title: '页面上间距',
					    val: 0,
					    min: 0
					},
					fillet:{
						title:'背景圆角',
						type: 0,
						list: [
						  {
						    val: "全部",
						    icon: "iconcaozuo-zhengti",
						  },
						  {
						    val: "单个",
						    icon: "iconcaozuo-bianjiao",
						  }
						],
						valName:'圆角值',
						val: 8,
						min: 0,
						valList:[
							{val:0},
							{val:0},
							{val:0},
							{val:0}
						]
					}
                },
				pageData: {},
				bottomBgColor:'',
				topConfig:0,
				bottomConfig:0,
				prConfig:0,
				styleConfig:0,
				imgBgUrl:0,
				headerBgColorLeft:'',
				headerBgColorRight:'',
				titleConfig:0,
				imgUrl:'',
				imgColorUrl:'',
				headerBntColor:'',
				headerBntColor2:'',
				titleTabVal:0,
				titleText:'',
				titleColor:'',
				titleNumber:0,
				titleTxtConfig:'',
				rightBntTxt:'',
				numberConfig:0,
				goodStyleConfig:0,
				bntNumber:0,
				imgRadius:0,
				toneConfig:0,
				goodsPriceColor:'',
				goodsPriceColor2:'',
				priceBgColorLeft:'',
				priceBgColorRight:'',
				bgColor:'',
				bgColor2:'',
				mTop:0,
				bgRadius:0,
				// bgRadius2:0,
				goodsNameColor:'',
				goodsNameColor2:'',
				goodsUnitPriceColor:'',
				goodsUnitPriceColor2:'',
				themeColor:''
            }
        },
        mounted () {
            this.$nextTick(() => {
                this.pageData = this.$store.state.mobildConfig.defaultArray[this.num]
                this.setConfig(this.pageData)
            })
        },
        methods: {
            setConfig (data) {
                if(!data) return
                if(data.mbConfig){
					this.styleConfig = data.styleConfig.tabVal;
					this.imgBgUrl = data.imgBgConfig.url;
					this.headerBgColorLeft = data.headerBgColor.color[0].item;
					this.headerBgColorRight = data.headerBgColor.color[1].item;
					this.titleConfig = data.titleConfig.tabVal;
					this.imgUrl = data.imgConfig.url;
					this.imgColorUrl = data.imgConfig2.url;
					this.headerBntColor = data.headerBntColor.color[0].item;
					this.headerBntColor2 = data.headerBntColor2.color[0].item;
					this.bntNumber = data.bntNumber.val;
					let tabVal = data.titleText.tabVal;
					this.titleTabVal = tabVal;
					this.titleText = data.titleText.tabList[tabVal].style;
					this.titleColor = data.titleColor.color[0].item;
					this.titleNumber = data.titleNumber.val;
					this.titleTxtConfig = data.titleTxtConfig.value;
					this.rightBntTxt = data.rightBntConfig.value;
					this.numberConfig = data.numberConfig.val;
					this.goodStyleConfig = data.goodStyleConfig.tabVal;
					let filletImg = data.filletImg.type;
					let filletValImg = data.filletImg.val;
					let valListImg = data.filletImg.valList;
					this.imgRadius = filletImg? valListImg[0].val+ 'px ' +valListImg[1].val + 'px ' + valListImg[3].val + 'px ' + valListImg[2].val +'px' : filletValImg +'px';
					this.toneConfig = data.toneConfig.tabVal;
					this.goodsPriceColor = data.goodsPriceColor.color[0].item;
					this.goodsPriceColor2 = data.goodsPriceColor2.color[0].item;
					this.priceBgColorLeft = data.priceBgColor.color[0].item;
					this.priceBgColorRight = data.priceBgColor.color[1].item;
					let bgColorLeft =  data.moduleColor.color[0].item;
					let bgColorRight =  data.moduleColor.color[1].item;
					this.bgColor = `linear-gradient(90deg,${bgColorRight} 0%,${bgColorLeft} 100%)`;
					let bgColorLeft2 =  data.moduleColor2.color[0].item;
					let bgColorRight2 =  data.moduleColor2.color[1].item;
					this.bgColor2 = `linear-gradient(90deg,${bgColorRight2} 0%,${bgColorLeft2} 100%)`;
					this.bottomBgColor = data.bottomBgColor.color[0].item;
					this.mTop = data.mbConfig.val;
					this.topConfig = data.topConfig.val;
					this.bottomConfig = data.bottomConfig.val;
					this.prConfig = data.prConfig.val;
					let fillet = data.fillet.type;
					let filletVal = data.fillet.val;
					let valList = data.fillet.valList;
					this.bgRadius = fillet? valList[0].val+ 'px ' +valList[1].val + 'px '+valList[3].val+'px '+ valList[2].val + 'px': filletVal +'px';
					// this.bgRadius2 = fillet? '0 0 '+valList[3].val+ 'px ' +valList[2].val + 'px': '0 0 '+filletVal +'px ' +filletVal + 'px';
					this.goodsNameColor = data.goodsNameColor.color[0].item;
					this.goodsNameColor2 = data.goodsNameColor2.color[0].item;
					this.goodsUnitPriceColor = data.goodsUnitPriceColor.color[0].item;
					this.goodsUnitPriceColor2 = data.goodsUnitPriceColor2.color[0].item;
					this.themeColor = `linear-gradient(90deg,${this.colorStyle.theme} 0%,${this.colorStyle.gradient} 100%)`;
                }
            }
        }
    }
</script>

<style scoped lang="stylus">
	.pointsMall{
		overflow: hidden;
		.title{
			font-size: 16px;
			color: #333;
			background-repeat: no-repeat;
			background-size: 100% 100%;
			width: 100%;
			height: 48px;
			display: flex
			justify-content: space-between
			align-items: center
			font-size: 16px;
			font-weight: 500;
			padding: 0 12px;
			img {
				width: 88px;
				height: 16px;
				display: block;
			}
			.more{
				font-size: 12px;
				color: #999;
				.iconfont{
					font-size: 12px;
				}
			}
		}
		.conter{
			padding: 0 0 16px 10px;
			// background: linear-gradient(90deg, #E93323 0%, #FF7931 100%);
		}
		.list{
			// background-color: #fff;
			padding: 10px 0 10px 10px;
			border-radius: 8px 0 0 8px;
			display: flex;
			overflow: hidden;
			&.on2{
				flex-wrap: wrap;
				padding-top: 0;
				.item{
					width: 47.4%;
					margin-right: 11px;
					margin-bottom: 10px;
					&:nth-of-type(2n){
						margin-right: 0;
					}
					&:nth-last-child(1),&:nth-last-child(2){
						margin-bottom: 0
					}
					.pictrue{
						width: 100%;
						height: 162px;
					}
					.name{
						font-size: 14px;
						margin-top: 5px;
					}
					.money{
						margin-top: 0;
						.num{
							&.on{
								font-size: 16px;
								font-family: D-DIN-PRO, D-DIN-PRO;
								font-weight: 600;
							}
						}
					}
				}
			}
			&.on{
				flex-wrap: wrap;
				padding-top: 0;
				.item{
					width: 30.7%;
					margin-right: 9px;
					margin-bottom: 10px;
					&:nth-last-child(1),&:nth-last-child(2),&:nth-last-child(3){
						margin-bottom: 0;
					}
					.pictrue{
						width: 100%;
						height: 106px;
					}
				}
			}
			.item{
				width: 112px;
				margin-right: 10px;
				.pictrue{
					width: 112px;
					height: 112px;
					background-color: #F3F9FF;
					img {
						width: 65px;
						height: 50px;
					}
				}
				.bottom{
					width: 98px;
					height: 18px;
					background: linear-gradient(90deg, #E93323 0%, #FF7931 100%);
					border-radius: 1px 10px 10px 10px;
					text-align: center;
					line-height: 18px;
					color: #fff;
					font-size: 11px;
					margin-top: 8px;
				}
				.money{
					font-size: 12px;
					color: #666;
					margin-top: 8px;
					img {
						width: 16px;
						height: 16px;
						display: block;
						margin-right: 4px;
					}
					.num{
						color: #E93323;
					}
				}
				.name{
					color: #282828;
					font-size: 13px;
					margin-top: 3px;
				}
			}
		}
	}
</style>